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Universal Local Area Network Controller 
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FEATURES 



24-Pin Embedded Network Controller/ 

Transceiver/ Dual-Port RAM 

Ideal for Industrial/Factory Automation 

and Automotive Applications 

Deterministic, 2.5 Mbps, Token Passing 

Protocol 

Minimal Microcontroller and Media 
Interface Logic Required 
Flexible Microcontroller Interface for 
Use with 80XX, 68XX, etc. 
Automatically Detects Type of 
Microcontroller Interface: 

- Non-Multiplexe d or Multiplexed Bus 

- Separate RD & WR Lines or DIR & DS 

Lines 

Full 2Kx8 On-Chip Dual-Port RAM 
Command Chaining for Top 
Performance 

Reduced Reconfiguration Times 
Sequential Access to Internal RAM 
Software Programmable Node ID 
Duplicate Node ID Detection 
Powerful Diagnostics 
Receive All Mode 



Data Rates from 2.5 Mbps to 156.25 Kbps 
24-Pin DIP or 28-Pin PLCC Package 
Flexible Media Interface: 

- Traditional Hybrid Interface for Long 
Distances 

- RS485 Differential Driver Interface for 
Low Cost, Low Power, High Reliability 

- Backplane Mode for Direct Connection to 
Media in Short Distance Applications 

Eight, 256-Byte Pages Allow 4 Pages TX 
and RX Plus Scratch-Pad Memory 
No Wait-State Arbitration 
Programmable TXEN Polarity 
Next ID Readable 

Internal Clock Prescaler for Slower 
Network Speed without Slowing 
Arbitration 

Operating Temperature Range of -40°C to 

+ 85°C, or 0°C to + 70°C 

Self-Reconfiguration Protocol 

Supports up to 255 Nodes 

Supports Various Network Topologies 

(Star, Tree, Bus...) 

CMOS, Single + 5 V Supply 



GENERAL 

SMC's COM20020 is a member of the family of 
Industrial Network Controllers from Standard 
Microsystems Corporation. The device is a 
special purpose communications controller for 
networking microcontrollers and intelligent 
peripherals in industrial, automotive, and 
embedded control environments using an 
ARCNET® protocol engine. The small 24-pin 



package, flexible microcontroller and media 
interfaces, eight-page message support, and 
extended temperature range of the COM20020 
make it the only true network controller 
optimized for use in industrial and automotive 
applications. Using an ARCNET protocol engine 
is the ideal solution for factory automation 
applications because it provides a token-passing 
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For more details on the ARCNET protocol engine and traditional dipulse signalling schemes, please 
refer to the ARCNET Local Area Network Standard , available from Standard Microsystems 
Corporation or the ARCNET Designer's Handbook, available from Datapoint Corporation. 



For more detailed information on cabling options including RS485, transformer-coupled RS-485 and 
Fiber Optic interfaces, please refer to the following technical note which is available from Standard 
Microsystems Corporation: Technical Note 7-5 - Cabling Guidelines for the COM20020 ULANC . 



protocol, a highly reliable and proven 
networking scheme, and a data rate of up to 
2.5 Mbps when using the COM20020. 

A token-passing protocol provides predictable 
response times because each network event 
occurs within a predetermined time interval, 
based upon the number of nodes on the 
network. The deterministic nature of ARCNET 
is essential in mission critical applications. 



The integration of the 2Kx8 RAM buffer on- 
chip, the Command Chaining feature, the 2.5 
Mbps maximum data rate, and the internal 
diagnostics make the COM 20020 the highest 
performance industrial communications device 
available. With only one COM20020 and one 
microcontroller, a complete communications 
node may be implemented. 

ARCNET is a registered trademark of Datapoint Corporation 



PIN CONFIGURATION 
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Packages: 24-Pin DIP or 28-Pin PLCC 
Ordering Information: 
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PACKAGE TYPE: P = Plastic, LJP = PLCC 

TEMP RANGE: (Blank) = Commercial: O'C to +70*C 
I = Industrial: -40* C to +85*C 



DEVICE TYPE: 20020 = Universal Local Area Network Controller 
(with 2K x 8 RAM) 
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DESCRIPTION OF PIN FUNCTIONS 
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MICROCONTROLLER INTERFACE 


1-3 


1-3 


Address 
0-2 


AO/MUX, 
A1 ,A2/ALE 


Input. On a non-multiplexed bus, these 
signals are directly connected to the low 
bits of the host address bus. On a 
multiplexed address/data bus, AO/MUX is 
tied low, A1 is left open, and A2 is tied to 
the Address Latch Enable signal of the 
host. A1 is connected to an internal pull- 
up resistor. 


4-11 


4-6,8-12 


Data 0-7 


AD0-AD2, 
D3-D7 


Input/Output. On a non-multiplexed bus, 
these signals are used as the data lines for 
the device. On a multiplexed address/data 
bus, AD0-AD2 act as the address lines 
(latched by ALE) and as the low data lines 
for the device. D3-D7 are always used for 
data only. These signals are connected to 
internal pull-up resistors. 


23 


27 


Read/Data 
Strobe 


RD/DS 


Input. On a 68XX-like bus, this active low 
signal is issued by the microcontroller as 
the data strobe signal to strobe the data 
onto the bus. On a 80XX-like bus, this 
active low signal is issued by the 
microcontroller to indicate a read 
operation. In this case, a logic "0" on this 
pin, when the COM20020 is accessed, 
enables data from the device to the data 
bus to be read by the microcontroller. 


22 


26 


Write/ 
Direction 


WR/DIR 


Input. On a 68XX-like bus, this signal is 
issued by the microcontroller as the 
Read/Write signal to determine the 
direction of data transfer. In this case, a 
logic " 1 " selects a read operation, while a 
logic "0" selects a write operation. In this 
case, data is actually strobed by the DS 
signal. On an SOXX-like* bus, this active 
low signal is issued by the microcontroller 
to indicate a write operation. In this case, 
a logic "0" on this pin, when the 
COM20020 is accessed, enables data 
from the data bus to be written to the 
device. 
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DESCRIPTION OF PIN FUNCTIONS 



DIP PIN 
NO. 


PLCC PIN 
NO. 


NAME 


SYMBOL 


DESCRIPTION 


19 


23 


Reset in 


RESET IN 


Input. This active low signal issued by the 
microcontroller executes a hardware reset. 
It is used to activate the internal reset 
circuitry within the COM20020. 


20 


24 


Interrupt 


IIM 1 n 


Output. This active low signal is 
generated by the COM20020 when an 
enabled interrupt condition occurs. INTR 
returns to its inactive state when the 
interrupt status condition or the 
corresponding interrupt mask bit is reset. 


21 


25 


Chip Select 




Input. This active low signal issued by the 
microcontroller selects the COM20020 for 
an access. 


TRANSMISSION MEDIA INTERFACE 


16,15 


19,18 


Pulse 2, 
Pulse 1 


PULSE2, 
PULSE1 


Output. In Normal Mode, these active low 
signals carry the transmit data information, 
encoded in pulse format, from the 
COM20020 to the media driver circuitry. 
When the device is in Backplane Mode, the 
PULSE 1 signal driver is programmable 
(push/pull or open-drain), while the 
PULSE2 signal provides a clock with 
frequency of crystal/4. PULSE1 is 
connected to a weak internal pull-up 
resistor in backplane mode. 


17 


20 


Receive In 


RXIN 


Input. This signal carries the receive data 
information from the line receiver circuitry 
to the COM20020. 


18 


21 


Transmit 
Enable 


TXEN 


Output. This signal is used in Backplane 
Mode to enable the line drivers for 
transmission. The polarity of the signal is 
programmable by grounding the PULSE2 
pin. This option is valid only in Backplane 
Mode. 



5 



DESCRIPTION OF PIN FUNCTIONS 



DIP PIN 


PLCC PIN 








NO. 


NO. 


NAME 


SVMBOL 




MISCELLANEOUS 


13,14 


16,17 


Crystal 
Oscillator 


XTAL1, 
XTAL2 


An external crystal should be connected to 
these pins. If an external TTL clock is 
used instead, it must be connected to 
XTAL1 with a 390Q pull-up resistor, and 
XTAL2 should be left floating. 


24 


15.28 


Power 
Supply 


v DD 


+ 5 Volt Power Supply pin. 


12 


7.14,22 


Ground 


v ss 


Ground pin. 
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ID refers to the identification number of Ins ID assigned to this node. 
NID refers to the next identification number that receives the token after 
after this ID passes it, 
SID refers to the source identification. 
DID refers to the destination identification. 

SOH refers to the start of header character; proceed* aU data packets. 



FIGURE 1 - COM20020 OPERATION 
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PROTOCOL DESCRIPTION 



n 




Communication on the network is based on a 
token passing protocol. Establishment of the 
network configuration and management of the 
network protocol are handled entirely by the 
COM20020's internal microcoded sequencer. 
A processor or intelligent peripheral transmits 
data by simply loading a data packet and its 
destination ID into the COM20020's RAM 
buffer, and issuing a command to enable the 
transmitter. When the COM20020 next 
receives the token, it verifies that the receiving 
node is ready by first transmitting a FREE 
BUFFER ENQUIRY message. If the receiving 
node transmits an ACKnowledge message, the 
data packet is transmitted followed by a 1 6-bit 
CRC. If the receiving node cannot accept the 
packet (typically its receiver is inhibited), it 
transmits a Negative AcKnowledge message 
and the transmitter passes the token. Once it 
has been established that the receiving node 
can accept the packet and transmission is 
complete, the receiving node verifies the 
packet. If the packet is received successfully, 
the receiving node transmits an ACKnowledge 
message (or nothing if it is not received 
successfully) allowing the transmitter to set the 
appropriate status bits to indicate successful or 
unsuccessful delivery of the packet. An 
interrupt mask permits the COM20020 to 
generate an interrupt to the processor when 
selected status bits become true. Figure 1 is a 
flow chart illustrating the internal operation of 
the COM20020. 

DATA RATES 

The COM20020 is capable of supporting data 
rates from 156.25 Kbps to 2.5 Mbps. The 
following protocol description assumes a 2.5 
Mbps data rate. For slower data rates, an 
internal clock divider scales down the clock 



frequency. Thus all timeout values are scaled 



up as shown in the following table: 







TIMEOUT 




DATA RATE 


SCALING 


CLOCK 


W/20MHz 


FACTOR 


PRESCALER 


XTAL 


IMULTIPY BY) 


+ 8 


2.5 Mbps 


1 


+ 16 


1.25 Mbps 


2 


+ 32 


625 Kbps 


4 


+ 64 


312.5 Kbps 


8 


+ 128 


156.25 Kbps 


16 



Example: IDLE LINE Timeout @ 2.5 Mbps = 
82 ys. IDLE LINE Timeout for 1 56.2 Kbps is 82 
//s • 1 6 = 1 .3 ms 

NETWORK RECONFIGURATION 

A significant advantage of the COM20020 is its 
ability to adapt to changes on the network. 
Whenever a new node is activated or 
deactivated, a NETWORK RECONFIGURATION 
is performed. When a new COM20020 is 
turned on (creating a new active node on the 
network), or if the COM20020 has not received 
an INVITATION TO TRANSMIT for 840mS, or if 
a software reset occurs, the COM 20020 causes 
a NETWORK RECONFIGURATION by sending a 
RECONFIGURE BURST consisting of eight marks 
and one space repeated 765 times. The 
purpose of this burst is to terminate all activity 
on the network. Since this burst is longer than 
any other type of transmission, the burst will 
interfere with the next INVITATION TO 
TRANSMIT, destroy the token and keep any 
other node from assuming control of the line. 

When any COM20020 senses an idle line for 
greater than 82//S, which occurs only when the 
token is lost, each COM20020 starts an internal 
timeout equal to 146/zs times the quantity 255 
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minus its own ID. It also sets the internally 
stored NID (next ID representing the next 
possible ID node) equal to its own ID. If the 
timeout expires with no line activity, the 
COM20020 starts sending INVITATION TO 
TRANSMIT with the Destination ID (DID) equal 
to the currently stored NID. Within a given 
network, only one COM20020 will timeout (the 
one with the highest ID number). After sending 
the INVITATION TO TRANSMIT, the 
COM20020 waits for activity on the line. If 
there is no activity for 74.7//S, the COM20020 
increments the NID value and transmits another 
INVITATION TO TRANSMIT using the NID equal 
to the DID. If activity appears before the 
74.7/jS timeout expires, the COM2002O 
releases control of the line. During NETWORK 
RECONFIGURATION, INVITATIONS TO 
TRANSMIT are sent to all NIDs. 

Each COM20020 on the network will finally 
have saved a NID value equal to the ID of the 
COM20020 that it released control to. At this 
point, control is passed directly from one node 
to the next with no wasted INVITATIONS TO 
TRANSMIT being sent to ID's not on the 
network, until the next NETWORK 
RECONFIGURATION occurs. When a node is 
powered off, the previous node attempts to 
pass the token to it by issuing an INVITATION 
TO TRANSMIT. Since this node does not 
respond, the previous node times out and 
transmits another INVITATION TO TRANSMIT 
to an incremented ID and eventually a response 
will be received. 

The NETWORK RECONFIGURATION time 
depends on the number of nodes in the 
network, the propagation delay between nodes, 
and the highest ID number on the network, but 
is typically within the range of 24 to 61 ms. 

BROADCAST MESSAGES 

Broadcasting gives a particular node the ability 
to transmit a data packet to all nodes on the 
network simultaneously. ID zero is reserved for 



this feature and no node on the network can be 
assigned ID zero. To broadcast a message, the 
transmitting node's processor simply loads the 
RAM buffer with the data packet and sets the 
DID equal to zero. Figure 8 illustrates the 
position of each byte in the packet with the DID 
residing at address 1H of the current page 
selected in the "Enable Transmit from Page f nn" 
command. Each individual node has the ability 
to ignore broadcast messages by setting the 
most significant bit of the "Enable Receive to 
Page fnn" command (see Table 6) to a logic 
"0". 

EXTENDED TIMEOUT FUNCTION 

There are three timeouts associated with the 
COM20020 operation. The values of these 
timeouts are controlled by bits 3 and 4 of the 
Configuration Register. 

Response Time 

The Response Time determines the maximum 
propagation delay allowed between any two 
nodes, and should be chosen to be larger 
than the round trip propagation delay between 
the two furthest nodes on the network plus the 
maximum turn around time (the time it takes a 
particular COM20020 to start sending a 
message in response to a received message) 
which is approximately 12.7//S. The round trip 
propagation delay is a function of the 
transmission media and network topology. For 
a typical system using RG62 coax in a 
baseband system, a one way cable propagation 
delay of 31/sS translates to a distance of about 
4 miles. The flow chart in Figure 1 uses a value 
of 74.7/yS (31 + 31 + 12.7) to determine if 
any node will respond. 

Idle Time 

The Idle Time is associated with a NETWORK 
RECONFIGURATION. Figure 1 illustrates that 
during a NETWORK RECONFIGURATION one 
node will continually transmit INVITATIONS TO 
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TRANSMIT until it encounters an active node. 
All other nodes on the network must distinguish 
between this operation and an entirely idle line. 



with an ALERT BURST consisting of 6 unit 
intervals of mark (logic "1"). Eight bit data 
characters are then sent, with each character 



During NETWORK RECONFIGURATION, activity 
will appear on the line every 82/sS. This 82//S 
is equal to the Response Time of 74.7//S plus 
the time it takes the COM20020 to start 
retransmitting another message (usually another 
INVITATION TO TRANSMIT). 

Reconfiguration Time 

If any node does not receive the token within 
the Reconfiguration Time, the node will initiate 
a NETWORK RECONFIGURATION. The ET2 and 
ET1 bits of the Configuration Register allow the 
network to operate over longer distances than 
the 4 miles stated earlier. The logic levels on 
these bits control the maximum distances over 
which the COM20020 can operate by 
controlling the three timeout values described 
above. For proper network operation, all 
COM20020's connected to the same network 
must have the same Response Time, Idle Time, 
and Reconfiguration Time. 

LINE PROTOCOL 

The ARCNET line protocol is considered 
isochronous because each byte is preceded by 
a start interval and ended with a stop interval. 
Unlike asynchronous protocols, there is a 
constant amount of time separating each data 
byte. Each byte takes exactly 1 1 clock 
intervals of 400ns each. As a result, one byte 
is transmitted every 4.4/sS and the time to 
transmit a message can be precisely 
determined. The line idles in a spacing (logic 
"0") condition. A logic "0" is defined as no line 
activity and a logic " 1 " is defined as a negative 
pulse of 200nS duration. A transmission starts 



preceded by 2 unit intervals of mark and one 
unit interval of space. Five types of 
transmission can be performed as described 
below: 

Invitations To Transmit 

An Invitation To Transmit is used to pass the 
token from one node to another and is sent by 
the following sequence: 

• An ALERT BURST 

• An EOT (End Of Transmission: ASCII code 
04H) 

• Two (repeated) DID (Destination 

ID) characters 



ALERT 


EOT 


DID 


DID 


BURST 









Free Buffer Enquiries 

A Free Buffer Enquiry is used to ask another 
node if it is able to accept a packet of data. It 
is sent by the following sequence: 

• An ALERT BURST 

• An ENQ (ENQuiry: ASCII code 85H) 

• Two (repeated) DID (Destination ID) 
characters 



ALERT 


ENQ 


DID 


DID 


BURST 
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Data Packets 

A Data Packet consists of the actual data being 
sent to another node. It is sent by the following 
sequence: 

• An ALERT BURST 

• An SOH {Start Of Header-ASCII code 
01 H) 

• An SID (Source ID) character 

• Two (repeated) DID (Destination ID) 
characters 



• A single COUNT character which is the 
2's complement of the number of data 
bytes to follow if a short packet is sent, or 
00H followed by a COUNT character if a 
long packet is sent 

• N data bytes where COUNT = 256-N (or 
512-N for a long packet) 

• Two CRC (Cyclic Redundancy Check) 
characters. The CRC polynomial used is: 
X 10 + X 15 + X 2 + 1. 



ALERT 


SOH 
















BURST 


SID 


DID 


DID 


COUNT 


data data 


CRC 


CRC 



Acknowledgements 



Negative Acknowledgements 



An Acknowledgement is used to acknowledge 
reception of a packet or as an affirmative 
response to FREE BUFFER ENQUIRIES and is 
sent by the following sequence: 

• An ALERT BURST 

• An ACK (ACKnowledgement-ASCII code 
86H) character 



A Negative Acknowledgement is used as a 
negative response to FREE BUFFER ENQUIRIES 
and is sent by the following sequence: 

• An ALERT BURST 

• A NAK (Negative Acknowledgement-ASCII 
code 1 5H) character 



ALERT 


ACK 


BURST 





ALERT 


NAK 


BURST 
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SYSTEM DESCRIPTION 



MICROCONTROLLER INTERFACE 



The top halves of Figures 2 and 3 illustrate 
typical COM20020 interfaces to the 
microcontrollers. The interfaces consist of an 
8-bit data bus, an address bus, and a control 
bus. In order to support a wide range of 
microcontrollers without requiring glue logic and 
without increasing the number of pins, the 
COM20O20 automatically detects and adapts to 
the type of microcontroller being used. 

Upon hardware reset, the COM20020 first 
determines whether the read and write control 
signals are separate READ and WRITE signals 
{like the 80XX) or DIRECTION and DATA 
STROBE {like the 68XX). To determine the type 
of control signals, the device requires the 
software to execute at least one write access to 
external memory before attempting to access 
the COM20020. The device defaults to 80XX- 
like signals. Once the type of control signals 
are determined, the COM20020 remains in this 
interface mode until the next hardware reset 
occurs. 

The second determination the COM20020 
makes is whether the bus is multiplexed or non- 
multiplexed. To determine the type of bus, the 
device requires the software to write to an odd 
memory location followed by a read to an odd 
location before attempting to access the 
COM20020. (The AO bit of the odd access tells 
the COM20020 the type of bus. Since 
multiplexed operation requires AO to be 
grounded, activity on the AO line tells the 
COM20020 that the bus is non-multiplexed. 
The device defaults to multiplexed operation. 

Both determinations may be made 
simultaneously by performing a WRITE followed 
by a READ operation to an odd location within 
the COM20020 Address space., Once the 



type of bus is determined, the COM20020 

■UlllUJIIli 

reset occurs. Whenever CS and RD are 
activated, the preset determinations are 
assumed as final and will not be changed until 
hardware reset. Refer to Description of Pin 
Functions for details on the related signals. 

All accesses to the internal RAM and the 
internal registers are controlled by the 
COM20020. The internal RAM is accessed via 
a pointer-based scheme (refer to the Sequential 
Access Memory section), and the internal 
registers are accessed via direct addressing. 
Many peripherals are not fast enough to take 
advantage of high-speed microcontrollers. 
Since microcontrollers do not typically have 
READY inputs, standard peripherals cannot 
extend cycles to extend the access time. The 
access time of the COM20020, on the other 
hand, is so fast that it does not need to limit 
the speed of the microcontroller. The 
COM20020 is designed to be flexible so that it 
is independent of the microcontroller speed. 

The COM20020 provides for no wait state 
arbitration via direct addressing to its internal 
registers and a pointer based addressing 
scheme to access its internal RAM. The pointer 
may be used in auto-increment mode for typical 
sequential buffer emptying or loading, or it can 
be taken out of auto-increment mode to 
perform random accesses to the RAM. The 
data within the RAM is accessed through the 
data register. Data being read is prefetched 
from memory and placed into the data register 
for the microcontroller to read. During a write 
operation, the data is stored in the data register 
and then written into memory. Whenever the 
pointer is loaded for reads with a new value, 
data is immediately prefetched to prepare for 
the first read operation. 
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FIGURE 2 - MULTIPLEXED, 8051 -LIKE BUS INTERFACE WITH RS-485 INTERFACE 
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FIGURE 3 - NON-MULTIPLEXED, 6801-LIKE BUS INTERFACE WITH RS-485 INTERFACE 
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TRANSMISSION MEDIA INTERFACE 

The bottom halves of Figures 2 and 3 illustrate 
the COM20020 interface to the transmission 
media used to connect the node to the network. 
Table 1 lists different types of cable which are 
suitable for ARCNET applications. 1 The user 
may interface to the cable of choice in one of 
three ways: 

Traditional Hybrid Interface 

The Traditional Hybrid Interface is that which is 
used with previous ARCNET devices. The 
Hybrid Interface is recommended if the node is 
to be placed in a network with other Hybrid- 
Interfaced nodes. The Traditional Hybrid 
Interface is for use with nodes operating at 2.5 
Mbps only. The transformer coupling of the 
Hybrid offers isolation for the safety of the 
system and offers high Common Mode 
Rejection. The Traditional Hybrid Interface uses 
circuits like SMC's HYC9068 or HYC9088 to 
transfer the pulse-encoded data between the 
cable and the COM20020. The COM20020 
transmits a logic " 1 " by generatin g two 10 0nS 
non-over lapping negative pulses, PULSE1 and 
PUL SE2. La ck o f pulses indicates a logic "0". 
The PULSE1 and PULSE2 signals are sent to the 
Hybrid, which creates a 200nS dipulse signal on 
the media. A logic "0" is transmitted by the 
absence of the dipulse. During reception, the 
200nS dipulse appearing on the media is 
coupled through the RF transformer of the LAN 
Driver, which produces a positive pulse at the 
RXIN pin of the COM20020. The pulse on the 
RXIN pin represents a logic "1 Lack of pulse 
represents a logic "0". Typically, RXIN pulses 
occur at multiples of 400nS. The COM20020 
can tolerate distortion of plus or minus lOOnS 
and still correctly capture and convert the RXIN 



1 Please refer to TN7-5 - Cabling Guidelines for 
the COM20020 ULANC, available from SMC, 
for recommended cabling distance, termination, 
and node count for ARCNET nodes. 



pulses to NRZ format. Figure 5 illustrates the 
events which occur in transmission or reception 
of data consisting of 1 , 1,0. 

Backplane Configuration 

The Backplane Open Drain Configuration is 
recommended for cost-sensitive, short-distance 
applications like backplanes and 
instrumentation. This mode is advantageous 
because it saves components, cost, and power. 

Since the Backplane Configuration encodes data 
differently than the traditional Hybrid 
Configuration, nodes utilizing the Backplane 
Configuration cannot communicate directly with 
nodes utilizing the Traditional Hybrid 
Configuration. 

The Backplane Configuration does not isolate 
the node from the media nor protect it from 
Common Mode noise, but Common Mode Noise 
is less of a problem in short distances. 

The COM20020 supplies a programmable 
output driver for Backplane Mode operation. A 
push/pull or open drain driver can be selected 
by programming the PI MODE bit of the Setup 
Register (see register descriptions for details.) 
The COM20020 defaults to an open drain 
output. 

The Backplane Configuration provides for direct 
connection between the COM20020 and the 
media. Only one pull-up resistor (for open drain 
only) is required somewhere on the media (not 
on each individual node). The PULSET signal, in 
this mode, is an open drain or push/pull driver 
and is used to directly drive the media. It 
issues a 200nS negative pulse to transmit a 
logic "1". Note that when used in the open- 
drain mode, the COM20020 does not have a 
fail/safe input on the RXIN pin. 



The PULSE 1 signal actually contains a weak 
pull-up resistor. This pull-up should not take 
the place of the resistor required on the media 
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FIGURE 4 - COM20020 NETWORK USING RS-485 DIFFERENTIAL TRANSCEIVERS 
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FIGURE 5 - DIPULSE WAVEFORM FOR DATA OF 1-1-0 
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for open drain mode. In typical applications, the 
serial backplane is terminated at both ends and 
a bias is provided by the external pull-up 
resistor. 

The RXIN signal is directly connected to the 
cable via an internal Schmitt trigger. A negative 
pulse on this input indicates a logic "1". Lack 
of pulse indicates a logic "0". For typical 
single-ended b ackplane applications, RXIN is 
connected to PULSE1 to make the serial 
backplane data line. A ground line (from the 
coax or twisted pair) should run in parallel with 
the signal. For applications requiring different 
treatment of the recei ve signal (like filtering or 
squelching), PULSE1 and RXIN remain as 
independent pins. External differential 
drivers/receivers for increased range and 
common mode noise rejection, for example, 
would require the signals to be independent of 
one another. When the device i s in Bac kplane 
Mode, the clock provided by the PULSE2 signal 
may be used for encoding the data into a 
different encoding scheme or other synchronous 
operations needed on the serial data stream. 

Differential Driver Configuration 

The Differential Driver Configuration is a special 
case of the Backplane Mode. It is a dc coupled 
configuration recommended for applications like 
car-area networks or other cost-sensitive 
applications which do not require direct 
compatibility with existing ARCNET nodes and 
do not require isolation. 



The Differential Driver Configuration cannot 
communicate directly with nodes utilizing the 
Traditional Hybrid Configuration. Like the 
Backplane Configuration, the Differential Driver 
Configuration does not isolate the node from 
the media. 

The Differential Driver interface includes a 
RS485 Driver/Receiver to transfer the data 
between the cable and the COM20020. The 
PULSE1 signal transmits the data, prov ided the 
Transmit Enable signal is active. The PULSE 1 
signal issues a 200nS negative pulse to 
transmit a logic "1". The RXIN signal receives 
the data. A negative pulse on this input 
indicates a logic "1". Lack of pulse indicates a 
logic "0". The transmitter portion of the 
COM20020 is di sable d dur ing reset and the 
PULSE1 , PULSE2 and TXEN pins are inactive. 

Programmable TXEN Polarity 

To accommodate transceivers with active high 
ENABLE pins, the COM20020 contains a 
programmable TXEN output. To prog ram the 
TXEN pin for an active high pulse, the PULSE2 
pin should be connected to gr ound. To retain 
the normal active low polarity, PULSE2 should 
be left open. The polarity determination is 
made at power on reset and is valid only for 
Backplane Mode operation only. The PULSE2 
pin should remain grounded at all times if an 
active high polarity is desired. 



17 



AO/MUX 
A1 

A2/BALE 



AD0-AD2, . 
D3-D7 



ADDRESS 

DECODING 

CIRCUITRY 




ADDITIONAL 
REGISTERS 



INTR 





STATUS/ 


< 


COMMAND 




REGISTER 



RESET IN 



RD/DS- 
WR/DIR- 

cs- 



RESETi 
LOGIC 



BUS 
ARBITRATION 
CIRCUITRY 



MICRO- 
SEQUENCER 
AND 
WORKING 
REGISTERS 



J 



I 



TX/RX 
LOGIC 



— ► PULSEI 
— ► PULS E2 
— ►TXEN 
< — RXIN 



OSCILLATOR 



XTAL1 
"XTAL2 



RECONFIGURATION 
TIMER 



NODE ID 
LOGIC 



FIGURE 6 - INTERNAL BLOCK DIAGRAM 



18 



Table 1 - Typical Media 



CABLE TYPE 


NOMINAL 
IMPEDANCE 


ATTENUATION 
PER 1000 FT, 
AT 5MHZ 


Rft-fi? Rplrlpn *8fi2fi2 


930. 


5.5dB 


RG-59/U Belden #89108 


75Q 


7.0dB 


RG-11/U Belden #89108 


75Q 


5.5dB 


IBM Type 1 # Belden #89688 


150Q 


7.0dB 


IBM Type 3* Telephone 
Twisted Pair Belden #1 155A 


100Q 


17.9dB 


COMCODE 26 AWG Twisted 
Pair Part #105-064-703 


105Q 


16.0dB 



* Non-plenum-rated cables of this type are also available. 



Note: For more detailed information on Cabling options including RS-485, transformer-coupled RS-485 
and Fiber Optic interfaces, please refer to TN7-5 - Cabling Guidelines for the COM20020 ULANC. 
available from Standard Microsystems Corporation. 



FUNCTIONAL DESCRIPTION 



MICROSEQUENCER 

The COM20020 contains an internal 
microsequencer which performs all of the 
control operations necessary to carry out the 
ARCNET protocol. It consists of a clock 
generator, a 544 x 8 ROM, a program counter, 
two instruction registers, an instruction 
decoder, a no-op generator, jump logic, and 
reconfiguration logic. 

The COM20020 derives a 5MHz and a 2.5MHz 
clock from the external crystal. These clocks 
provide the rate at which the instructions are 
executed within the COM20020. The 5MHz 
clock is the rate at which the program counter 
operates, while the 2.5MHz clock is the rate at 
which the instructions are executed. The 
microprogram is stored in the ROM and the 
instructions are fetched and then placed into 
the instruction registers. One register holds the 



op code, while the other holds the immediate 
data. Once the instruction is fetched, it is 
decoded by the internal instruction decoder, at 
which point the COM20020 proceeds to 
execute the instruction. When a no-op 
instruction is encountered, the microsequencer 
enters a timed loop and the program counter is 
temporarily stopped until the loop is complete. 
When a jump instruction is encountered, the 
program counter is loaded with the jump 
address from the ROM. The COM20020 
contains an internal reconfiguration timer which 
interrupts the microsequencer if it has timed 
out. At this point the program counter is 
cleared and the MYRECON bit of the Diagnostic 
Status Register is set. 

INTERNAL REGISTERS 

The COM20020 contains eight internal 
registers. Tables 2 and 3 illustrate the 
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Table 2 - Read Register Summary 



REGISTER 


MSB 






READ 






LSB 


ADDRESS 


STATUS 


Rl 


X 


X 


| POR 


TEST 


RECON | 


TMA 


TA 


00 


DIAG. 
STATUS 


MY- 
RECON 




DUPID 


RCVACT | TOKEN I EXCNAKj TENTID j 


NEW | 
NEXTID 


X 


01 


ADDRESS 
PTR HIGH 


RDDATA 


AUTO- 
INC 


X 


X 


X 


A10 | 


A9 


A8 


02 


ADDRESS 
PTR LOW 


A7 


A6 


A5 


A4 


A3 


A2 


A1 


AO 


03 


DATA 


D7 


D6 


D5 


| D4 


D3 


D2 j 


D1 


DO 


04 


RESERVED 


X 


X 


X 


X 

j 


X 

i 1 


X 

1 


X 


X 


05 


CONFIG- 
URATION 




RESET 




CCHEN 




TXEN 


ET1 


ET2 


BACK- | 
PLANE | 


SUB- 
AD1 


SUB- 
ADO 


06 


TENT1D 


TID7 




TID6 


TID5 


| ~ 

TID4 




TID3 


r 

TID2 \ 


1 

TID1 


TIDO 




NODEID 


NID7 


NID6 


NID5 


NID4 


NID3 


NID2 | 


NID1 


NIDO 


07 


SETUP 


P1MODE 


FOUR 
NAKS 


ET3 


I RCV_ 
ALL 


CKP3 


CKP2 


CKP1 


SLOW 
ARB 


NEXT ID 


NXTID7 


NXTID6 


NXTID5 


|NXTID4 


NXTID3 


NXTID2 j 


NXTID1 


NXTIDO 
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Table 3 - Write Register Summary 



ADDRESS 


MSB 






WRITE 






LSB 


REGISTER 


00 


ri i 


| 







1 


EXCNAK 


RECON j 


NEW j j. 
NEXTIDj 


INTERRUPT 
MASK 


01 


p 

D7 | 


r 

D6 j 


D5 


D4 


1 

D3 


r 

D2 | 


D1 


DO 


COMMAND 


02 


RDDATAj 


AUTO- I 
INC ! 











A10 | 


A9 


A8 
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PTR HIGH 


03 
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A4 


A3 


A2 I 


A1 


AO 


ADDRESS 
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04 


D7 

Uf i 


i 

UO 


Do 


D4 


D3 


i 

\ 


D1 


DO 
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05 




'■- 




i 

















i- 
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06 


RESET | 
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SUB- 
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URATION 




r 
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r 
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07 
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NID5 


NID4 


NID3 
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NIDO 


NODEID 
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FOUR i 
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RCV_ 
ALL 


CKP3 


CKP2 | 
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ARB 
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COM20020 register map. Reserved locations 
should not be accessed. All undefined bits are 
read as undefined and must be written as fogic 



Tentative ID Register 

The Tentative ID Register is a read/write 8-bit 



"0". 

Interrupt Mask Register (IMR) 

The COM20020 is capable of generating an 
interrupt signal when certain status bits become 
true. A write to the IMR specifies which status 
bits will be enabled to generate an interrupt. 
The bit positions in the IMR are in the same 
position as their corresponding status bits in the 
Status Register and Diagnostic Status Register. 
A logic "1" in a particular position enables the 
corresponding interrupt. The Status bits 
capable of generating an interrupt include the 
Receiver Inhibited bit, New Next ID bit, 
Excessive NAK bit, Reconfiguration Timer bit, 
and Transmitter Available bit. No other Status 
or Diagnostic Status bits can generate an 
interrupt. 

The five maskable status bits are ANDed with 
their respective mask bits, and the results are 
ORed to produce the interrupt signal. An Rl 
or TA interrupt is masked when the 
corresponding mask bit is reset to logic "0", but 
will reappear when the corresponding mask bit 
is set to logic "1" again, unless the interrupt 
status condition has been cleared by this time. 
A RECON interrupt is cleared when the "Clear 
Flags" command is issued. An EXCNAK 
interrupt is cleared when the "POR Clear Flags" 
command is issued. A New Next ID interrupt is 
cleared by reading the Next ID Register. The 
Interrupt Mask Register defaults to the value 
0000 0000 upon hardware reset. 

Data Register 

This read/write 8-bit register is used as the 
channel through which the data to and from the 
RAM passes. The data is placed in or retrieved 
from the address location presently specified by 
the address pointer. The contents of the Data 
Register are undefined upon hardware reset. 



register accessed when the Sub Address Bits 
are set up accordingly (please refer to the 
Configuration Register). The Tentative ID 
Register can be used while the node is on-line 
to build a network map of those nodes existing 
on the network. It minimizes the need for 
operator interaction with the network. The 
node determines the existence of other nodes 
by placing a Node ID value in the Tentative ID 
Register and waiting to see if the Tentative ID 
bit of the Diagnostic Status Register gets set. 
The network map developed by this method is 
only valid for a short period of time, since 
nodes may join or depart from the network at 
any time. When using the Tentative ID feature, 
a node cannot detect the existence of the next 
logical node to which it passes the token. The 
Next ID Register will hold the ID value of that 
node. The Tentative ID Register defaults to the 
value 0000 0000 upon hardware reset only. 

Node ID Register 

The Node ID Register is a read/write 8-bit 
register accessed when the Sub Address Bits 
are set up accordingly {please refer to the 
Configuration Register). The Node ID Register 
contains the unique value which identifies this 
particular node. Each node on the network 
must occupy a unique Node ID value at all 
times. The Duplicate ID bit of the Diagnostic 
Status Register helps the user find a unique 
Node ID. Refer to the Initialization Sequence 
section for further detail on the use of the 
DUPID bit. The core of the COM20020 does 
not wake up until a Node ID other than zero is 
written into the Node ID Register. During this 
time, no microcode is executed, no tokens are 
passed by this node, and no reconfigurations 
are caused by this node. Once a non-zero 
NodelD is placed into the Node ID Register, the 
core wakes up but will not join the network 
until the TXEN bit of the Configuration Register 
is set. While the Transmitter is disabled, the 



Receiver portion of the device is still functional 
and will provide the user with useful information 
about the network. The Node ID Register 
defaults to the value 0000 0000 upon hardware 
reset only. 

Next ID Register 

The Next ID Register is an 8-bit, read-only 
register, accessed when the sub-address bits 
are set up accordingly (please refer to the 
Configuration Register). The Next ID Register 
holds the value of the Node ID to which the 
COM20020 will pass the token. When used in 
conjunction with the Tentative ID Register, the 
Next ID Register can provide a complete 
network map. The Next ID Register is updated 
each time a node enters/leaves the network or 
when a network reconfiguration occurs. Each 
time the microsequencer updates the Next ID 
Register, a New Next ID interrupt is generated. 
This bit is cleared by reading the Next ID 
Register. Default value is 0000 0000 upon 
hardware or software reset. 

Status Register 

The COM20020 Status Register is an 8-bit 
read-only register. All of the bits, except for 
bits 5 and 6, are software compatible with 
previous SMC ARCNET devices. In previous 
SMC ARCNET devices the Extended Timeout 
status was provided in bits 5 and 6 of the 
Status Register. In the COM20020, the 
COM90C66, and the COM90C165, these bits 
exist in and are controlled by the Configuration 
Register. The Status Register contents are 
defined as in Table 4, but are defined differently 
during the Command Chaining operation. 
Please refer to the Command Chaining section 
for the definition of the Status Register during 
Command Chaining operation. The Status 
Register defaults to the value 1XX1 0001 upon 
either hardware or software reset. 



Diagnostic Status Register 

The Diagnostic Status Register contains seven 
read-only bits which help the user troubleshoot 
the network or node operation. Various 
combinations of these bits and the TXEN bit of 
the Configuration Register represent different 
situations. All of these bits, except the 
Excessive NAcK bit and the New Next ID bit, 
are reset to logic "0" upon reading the 
Diagnostic Status Register or upon software or 
hardware reset. The EXCNAK bit is reset by 
the "POR Clear Flags" command or upon 
software or hardware reset. The Diagnostic 
Status Register defaults to the value 0000 
000X upon either hardware or software reset. 

Command Register 

Execution of commands are initiated by 
performing microcontroller writes to this 
register. Any combinations of written data 
other than those listed in Table 6 are not 
permitted and may result in incorrect chip 
and/or network operation. 

Address Pointer Registers 

These read/write registers are each 8-bits wide 
and are used for addressing the internal RAM. 
New pointer addresses should be written by 
first writing to the High Register and then 
writing to the Low Register because writing to 
the Low Register loads the address. The 
contents of the Address Pointer High and Low 
Registers are undefined upon hardware reset. 

Configuration Register 

The Configuration Register is a read/write 
register which is used to configure the different 
modes of the COM20020. The Configuration 
Register defaults to the value 0001 1000 upon 
hardware reset only. 
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Setup Register 




111!! 



accessed when the Sub Address Bits are set up 
accordingly (see the bit definitions of the 
Configuration Register). The Setup Register 
allows the user to change the network speed 
(data rate) or the arbitration speed 



independentl y, invoke the Receive All feature, 
change the PULSE1 driver type, and reduce 





|f|Cjorof9, Thed^a. 



rate may be slowed to 156.25Kbps and/or the 
arbitration speed may be slowed by a factor of 
two. The Setup Register defaults to the value 
0000 0000 upon hardware reset only. 



Table 4 - Status Register 



BIT 


BIT NAME 


SYMBOL 


DESCRIPTION 


7 


Receiver 
Inhibited 


Rl 


This bit, if high, indicates that the receiver is not enabled because 
either an "Enable Receive to Page fnn" command was never issued, 
or a packet has been deposited into the RAM buffer page fnn as 
specified by the last "Enable Receive to Page fnn" command. No 
messages will ba received until this command is issued, and once the 
message has been received, the Rl bit is set, thereby inhibiting the 
receiver. The Rl bit is cleared by issuing an "Enable Receive to Page 
fnn" command. This bit, when set, will cause an interrupt if the 
corresponding bit of the Interrupt Mask Register (IMR) is also set. 


6,5 


(Reserved) 




These bits are undefined. 


4 


Power On Reset 


POR 


This bit, if high, indicates that the COM20020 has been reset by 
either a software reset, a hardware reset, or writing 00H to the Node 
ID Register. The POR bit is cleared by the "Clear Flags" command. 


3 


Test 


TEST 


This bit is intended for test and diagnostic purposes. It is a logic "0" 
under normal operating conditions. 


2 


Reconfiguration 


RECON 


This bit, if high, indicates that the Line Idle Timer has timed out 
because the RXIN pin was idle for 82pS, The RECON bit is cleared 
during a "Clear Flags" command. This bit, when set, will cause an 
interrupt if the corresponding bit in the IMR is also set. The interrupt 
service routine should consist of examing the MYRECON bit of the 
Diagnostic Status Register to determine whether there are 
consecutive reconfigurations caused by this node. 


1 


Transmitter 

Message 

Acknowledged 


TMA 


This bit, if high, indicates that the packet transmitted as a result of an 
"Enable Transmit from Page fnn" command has been acknowledged. 
This bit should only be considered valid after the TA bit (bit 0) is set. 
Broadcast messages are never acknowledged. The TMA bit is cleared 
by issuing the "Enable Transmit from Page fnn" command. 





Transmitter 
Available 


TA 


This bit, if high, indicates that the transmitter is available for 
transmitting. This bit is set at the conclusion of an "Enable Transmit 
from Page fnn" command or upon execution of a "Disable 
Transmitter" command. The TA bit is cleared by issuing the "Enable 
Transmit from Page fnn" command after the node next receives the 
token. This bit, when set, will cause an interrupt if the corresponding 
bit in the IMR is also set. 
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Table 5 - Diagnostic Status Register 



BIT 


BIT NAME 


SYMBOL 


DESCRIPTION 


7 


My 

Reconfiguration 


MY- 
RECON 


This bit, if high, indicates that a past reconfiguration was caused by 
this node. It is set when the Lost Token Timer times out, and is 
typically read following an interrupt caused by RECON. Refer to the 
Improved Diagnostics section for further detail. 


6 


Duplicate ID 


DUPID 


This bit, if high, indicates that the value in the Node ID Register 
matches both Destination ID characters of the token and a response 
to this token has occurred. The EOT character and the trailing zero's 
are also verified. A logic "1" on this bit indicates a duplicate Node ID, 
thus the user should write a new value into the Node ID Register. 
This bit is only useful for duplicate ID detection when the device is off 
line, that is, when the transmitter is off. When the device is on tine it 
will be set every time the device gets the token. This bit is reset 
automatically upon reading the Diagnostic Status Register. Refer to 
the Improved Diagnostics section for further detail. 


c 


D a/* AIWA 

Activity 


RCVACT 


This bit, if high, indicates that data activity (logic "1") was detected 
on the RXIN pin of the device. Refer to the Improved Diagnostics 
section for further detail. 


4 


Token Seen 


TOKEN 


This bit, if high, indicates that a token has been seen on the network, 
sent by a node other than this one. Refer to the Improved Diagnostic 
section for further detail. 


3 


Excessive NAK 


EXCNAK 


This bit, if high, indicates that either 128 or 4 Negative 
Acknowledgements have occurred in response to the Free Buffer 
Enquiry. This bit is cleared upon the "POR Clear Flags" command. 
Reading the Diagnostic Status Register does not clear this bit. This 
bit, when set, will cause an interrupt if the corresponding bit in the 
IMR is also set. Refer to the Improved Diagnostics section for further 
detail. 


2 


Tentative ID 


TENTID 


This bit, if high, indicates that a response to a token whose DID 
matches the value in the Tentative ID Register has occurred. In 
addition, the EOT character is checked. The second DID and the 
trailing zero's are not checked. Since each node sees every token 
passed around the network, this feature can be used with the device 
on-line in order to build and update a network map. Refer to the 
Improved Diagnostics section for further detail. 


1 


New Next ID 


NEW 
NXTID 


This bit, if high, indicates that the Next ID Register has been updated 
and that a node has either joined or left the network. Reading the 
Diagnostic Status Register does not clear this bit. This bit, when set, 
will cause an interrupt if the corresponding bit in the IMR is also set. 
The bit is cleared by reading the Next ID Register. 


1.0 


{Reserved) 




These bits are undefined. 



25 



Table 6 - Command Register 



DATA 


COMMAND 


DESCRIPTION 


0000 0000 


Clear 


This command is used onfy in the Command Chaining operation. 




Transmit 
Interrupt 


Please refer to the Command Chaining section for definition of this 
command. 


OOOOOOOI 


Disable 
Transmitter 


This command will cancel any pending transmit command 
(transmission that has not yet started) and will set the TA 
(Transmitter Available) status bit to logic " 1 " when the COM20020 
next receives the token. 


0000 0010 


Disable 
Receiver 


This command will cancel any pending receive command. If the 
COM20020 is not yet receiving a packet, the Rl (Receiver Inhibited) 
bit will be set to logic "1" the next time the token is received. If 
packet reception is already underway, reception will run to its 
normal conclusion. 


bOfn nlOO 


Enable 
Receive to 
Page fnn 


This command allows the COM20020 to receive data packets into 
RAM buffer page fnn and resets the Rl status bit to logic "0". The 
values placed in the "nn" bits indicate the page that the data will be 
received into (page 0, 1, 2, or 3). If the value of "f" is a logic "1", 
en offset of 256 bytes will be added to that page specified in "nn", 
allowing a finer resolution of the buffer. Refer to the Selecting RAM 
Page Size section for further detail. If the value of "b" is logic "1", 
the device will also receive broadcasts (transmissions to ID zero). 
The Rl status bit is set to logic "1" upon successful reception of a 
message. 


OOfn n01 1 


Enable 

Transmit from 
Page fnn 


This command prepares the COM20020 to begin a transmit 
sequence from RAM buffer page fnn the next time it receives the 
token. The values of the "nn" bits indicate which page to transmit 
from (0, 1, 2, or 3). If "f" is logic "1", an offset of 256 bytes is 
added to that page specified in "nn", allowing a finer resolution of 
the buffer. Refer to the Selecting RAM Page Size section for further 
detail. When this command is loaded, the TA and TMA bits are 
reset to logic "0". The TA bit is set to logic "1 " upon completion of 
the transmit sequence. The TMA bit will have been set by this time 
if the device has received an ACK from the destination node. The 
ACK is strictly hardware level, sent by the receiving node before its 
microcontroller is even aware of message reception. Refer to Figure 

1 ff\ t oto i 1 o nf fka +r anemit c aj*ii ifinra onH its ralatinn tKo ~T" A a r\s4 

I iui uuiaiis kj\ inu iianoum sd^uoiH/O anu iio ruiauuii lu inu in aitu 

TMA status bits. 


0000 c101 


Define 

Configuration 


This command defines the maximum length of packets that may be 
handled by the device. If "c" is a logic "1", the device handles both 
long and short packets. If "c" is a logic "0", the device handles only 
short packets. 


OOOr p1 10 


Clear Flags 


This command resets certain status bits of the COM20020. A logic 
"1" on "p" resets the POR status bit and the EXCNAK Diagnostic 
status bit. A logic "1" on "r" resets the RECON status bit. 


0000 1000 


Clear 

Receive 

Interrupt 


This command is used only in the Command Chaining operation. 
Please refer to the Command Chaining section for definition of this 
command. 



Table 7 - Address Pointer High Register 



BIT 


BIT NAME 


SYMBOL 


DESCRIPTION 


7 


Read Data 


RDDATA 


This bit tells the COM20020 whether the following 
access will be a read or write. A logic " 1 " prepares the 
device for a read, a logic "0" prepares it for a write. 


6 


Auto Increment 


AUTOINC 


This bit controls whether the address pointer will 
increment automatically. A logic "1" on this bit allows 
auiomaXiu increment ot ine pointer aiicr cdtn auueas, 

while a logic "0" disables this function. Please refer to 
the Sequential Access Memory section for further 
detail. 


5-3 


(reserved) 




These bits are undefined. 


2-0 


Address 10-8 


A10-A8 


These bits hold the upper three address bits which 
provide addresses to RAM. 


Table 8 - Address Pointer Low Register 


BIT 


BIT NAME 


SYMBOL 


DESCRIPTION 


7-0 


Address 7-0 


A7-A0 


These bits hold the lower 8 address bits which provide 
the addresses to RAM. 
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Table 9 - Configuration Register 



BIT 



BIT NAME 



SYMBOL 



DESCRIPTION 



Reset 



RESET 



A software reset of the COM20020 is executed by writing a 
logic "1" to this bit. A software reset does not reset the 
microcontroller interface mode, nor does it affect the 
Configuration Register. The only registers that the software 
reset affect are the Status Register, the Next ID Register, and 
the Diagnostic Status Register. This bit must be brought back 
to logic "0" to release the reset. 



Command 
Chaining Enable 



CCHEN 



This bit, if high, enables the Command Chaining operation of 
the device. Please refer to the Command Chaining section for 
further details. A low level on this bit ensures software 
compatibility with previous SMC ARCNET devices. 



Transmit Enable 



TXEN 



When low, this bit disables transmissions by keeping PULSE1 , 



PULSE2 if in non-Backplane Mode, and TXENABLE inactive. 
When high, it enables the above signals to be activated during 
transmissions. This bit defaults low upon reset. This bit is 
typically enabled once the Node ID is determined, and never 
disabled during normal operation. Please refer to the Improved 
Diagnostics section for details on evaluating network activity. 



4,3 



Extended 
Timeout 1,2 



ET1 , ET2 



These bits allow the network to operate over longer distances 
than the default 4 miles by controlling the Response, Idle, and 
Reconfiguration Times. All nodes should be configured with the 
same timeout values for proper network operation. The bit 
combinations follow: 







Response 


IdleTime 


Reconfig 


ET2 


III 


Time (pS) 


(uS) 


Time (mS) 








1193.6 


1312 


1680 





1 


596.8 


656 


1680 


1 





298.4 


328 


1680 


1 


1 


74.7 


82 


840 



Backplane 



BACK- 
PLANE 



A logic "1" on this bit puts the device into Backplane Mode 
signalling which is used for Open Drain and Differential Driver 
interfaces. 



1,0 



Sub Address 1,0 



SUBAD 1,0 



These bits determine which register at address 07 may be 
accessed. The combinations are as follows: 

SUBAD1 SU8AD0 Register 



Tentative ID 
Node ID 
Setup 
Next ID 



Table 10- Setup Register 



BIT 



BIT NAME 



SYMBOL 



DESCRIPTION 



Pulse 1 Mode 



P1MODE 



This bit determines the type of PULSE 1 output driver used in 
Backplane Mode. When high, a push/pull output is used. 
When low, an open drain output is used. The default is open 
drain. 



Four NACKS 



FOUR 
NACKS 



This bit, when set, will cause the EXNACK bit in the 
Diagnostic Status Register to set after four NACKs to Free 
Buffer Enquiry are detected by the COM20020. This bit, 
when reset, will set the EXNACK bit after 1 28 NACKs to Free 
Buffer Enquiry. The default is 128. 



ET3 



ET3 



This bit, when set, scales down protocol timeout values to 
optimize network performance in short topologies. Provides a 
scaling factor of + 3. Defaults to a zero. Must be reset to be 
ARCNET compliant. 



Receive All 



RCVALL 



This bit, when set, allows the COM20020 to receive all valid 
data packets on the network, regardless of their destination 
ID. This mode can be used to implement a network monitor 
with the transmitter on- or off-line. Note that ACKs are only 
sent for packets received with a destination ID equal to the 
COM20020's programmed node ID. This feature can be used 
to put the COM20020 in a 'listen-only' mode, where the 
transmitter is disabled and the COM20020 is not passing 
tokens. Defaults low. 



3,2,1 



Clock Prescaler Bits 
2,1,0 



CKP2.1.0 



These bits are used to determine the data rate of the 
C0M20020. The following table is for a 20MHz crystal: 



CKP2 


CKP1 


CKPO 


DIVISOR 


SPEED 











8 


2.5Mbs 








1 


16 


1 .25Mbs 





1 





32 


625Kbs 





1 


1 


64 


312.5Kbs 


1 








128 


156.25Kbs 


1 





1 


256 


Reserved 


1 


1 







Reserved 


1 


1 


1 




Reserved 



NOTE: The lowest data rata achievable by the COM20020 is 
156.25Kbs. A divide by 256 is provided for those systems 
that use faster clock speeds. Defaults to 000 or 2.5Mbs. 



Slow Arbitration 
Select 



SLW-ARB 



This bit, when set, will divide the arbitration clock by 2. 
Memory cycle times will increase when slow arbitration is 
selected. 

NOTE: For clock speeds greater than 20 MHz, SLOWARB 
must be set. Defaults to low. 
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Data Register 
I/O Address 04H 



D0-D7 



Memory 
Data Bus 

—h 



8 



Address Pointer Register 
I/O Address 02H I/O Address 03H 



High 


Low 




- 


11 -Bit Counter 



Memory 
Address Bus 

i 



11 



2Kx8 
INTERNAL 
RAM 



FIGURE 7 - SEQUENTIAL ACCESS OPERATION 
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INTERNAL RAM 

The integration of the 2K x 8 RAM in the 
COM20020 represents significant real estate 
savings. The most obvious benefit is the 24-pin 
package in which the device is now placed (a 
direct result of the integration of RAM). In 
addition, the PC board is now free of the 
cumbersome external RAM, external latch, and 
multiplexed address/data bus and control 
functions which were necessary to interface to 
the RAM. 

The integration of RAM represents significant 
cost savings because it isolates the system 
designer from the changing costs of external 
RAM and it minimizes reliability problems, 
assembly time and costs, and layout 
complexity. 

Sequential Access Memory 

The internal RAM is accessed via a pointer- 
based scheme. Rather than interfering with 
system memory, the internal RAM is indirectly 
accessed through the Address High and Low 
Pointer Registers. The data is channeled to and 
from the microcontroller via the 8-bit data 
register. For example: a packet in the internal 
RAM buffer is read by the microcontroller by 
writing the corresponding address into the 
Address Pointer High and Low Registers {offsets 
02H and 03H). Note that the High Register 
should be written first, followed by the Low 
Register, because writing to the Low Register 
loads the address. At this point the device 
accesses that location and places the 
corresponding data into the data register. The 
microcontroller then reads the data register 
{offset 04H) to obtain the data at the specified 
location. If the Auto Increment bit is set to 
logic "1", the device will automatically 
increment the address and place the next byte 
of data into the data register, again to be read 
by the microcontroller. This process is 
continued until the entire packet is read out of 



RAM. Refer to Figure 7 for an illustration of the 
Sequential Access operation. 

When switching between reads and writes, the 
pointer must first be written with the starting 
address. The pointer may be read at any time 
to allow the microcontroller to save the present 
pointer value before going into a subroutine. At 
feast one cycle time should separate the pointer 
being loaded and the first read (see timing 
parameters). 

Access Speed 

The COM20020 is able to accommodate very 
fast access cycles to its registers and buffers. 
Arbitration to the buffer does not slow down 
the cycle because the pointer based access 
method allows data to be prefetched from 
memory and stored in a temporary register. 
Likewise, data to be written is stored in the 
temporary register and then written to memory. 

For systems which do not require quick access 
time, the arbitration clock may be slowed down 
by setting bit of the Setup Register equal to 
logic "1". Since the Slow Arbitration feature 
divides the input clock by two, the duty cycle 
of the input clock may be relaxed. 

SOFTWARE INTERFACE 

The microcontroller interfaces to the 
COM20020 via software by accessing the 
various registers. These actions are described 
in the Internal Registers section. The software 
flow for accessing the data buffer is based on 
the Sequential Access scheme. The basic 
sequence is as follows: 

• Disable Interrupts 

• Write to Pointer Register High {specifying 
Auto-Increment mode.) 

• Write to Pointer Register Low {this loads 
the address.) 

• Enable Interrupts 
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• Read or write the Data Register (repeat as 
many times as necessary to empty or fill the 
buffer.) 



network data, packets to be sent later, or as 
extra memory for the system, which may be 
indirectly accessed. 



• The pointer may now be read to determine 
how many transfers were completed. 

The software flow for controlling the 
Configuration, Node ID, Tentative ID, and Next 
ID registers is generally limited to the 
initialization sequence and the maintenance of 
the network map. 

Additionally, it is necessary to understand the 
details of how the other Internal Registers are 
used in the transmit and receive sequences and 
to know how the internal RAM buffer is 
properly set up. The sequence of events that 
tie these actions together is discussed as 
follows. 

Selecting RAM Page Size 

During normal operation, the 2K x 8 of RAM is 
divided into four pages of 51 2 bytes each. The 
page to be used is specified in the "Enable 
Transmit (Receive) from (to) Page fnn" 
command, where "nn" specifies page 0, 1 , 2, or 
3. This allows the user to have constant 
control over the allocation of RAM. 

When the Offset bit "f" (bit 5 of the "Enable 
Transmit (Receive) from (to) Page fnn" 
command word) is set to logic "1 ", an offset of 
256 bytes is added to the page specified. For 
example: to transmit from the second half of 
page 0, the command "Enable Transmit from 
Page fnn" (fnn = 1 00 in this case) is issued by 
writing 0010 0011 to the Command Register. 
This allows a finer resolution of the buffer pages 
without affecting software compatibility. This 
scheme is useful for applications which 
frequently use packet sizes of 256 bytes or 
less, especially for microcontroller systems with 
limited memory capacity. The remaining 
portions of the buffer pages which are not 
allocated for current transmit or receive packets 
may be used as temporary storage for previous 



If the device is configured to handle both long 
and short packets (see "Define Configuration" 
command), then receive pages should always 
be 512 bytes long because the user never 
knows what the length of the receive packet 
will be. In this case, the transmit pages may be 
made 256 bytes long, leaving at least 512 
bytes free at any given time. Even if the 
Command Chaining operation is being used, 
512 bytes is still guaranteed to be free because 
Command Chaining only requires two pages for 
transmit and two for receive (in this case, two 
256 byte pages for transmit and two 512 byte 
pages for receive, leaving 512 bytes free). 
Please note that it is the responsibility of 
software to reserve 512 bytes for each receive 
page if the device is configured to handle long 
packets. The COM20020 does not check page 
boundaries during reception. 

If the device is configured to handle only short 
packets, then both transmit and receive pages 
may be allocated as 256 bytes long, freeing at 
least 1 KByte at any given time. 

Even if the Command Chaining operation is 
being used, 1 KByte is still guaranteed to be free 
because Command Chaining only requires two 
pages for transmit and two for receive (in this 
case, a total of four 256 byte pages, leaving 1K 
free). 

The general rule which may be applied to 
determine where in RAM a page begins is as 
follows: 

Address = (nn x 512) + (fx 256). 
Transmit Sequence 

During a transmit sequence, the microcontroller 
selects a 256 or 51 2 byte segment of the RAM 
buffer and writes into it. The appropriate buffer 
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SHORT PACKET 




LONG PACKET 


ADDRESS 



FORMAT 


ADDRESS 




FORMAT 


SID 


o i r~\ 






DID 


1 


u\u 




o 


COUNT = 256-N 


2 









NOT USED 


3 


COUNT = 51 2-N 












COUNT 


DATA BYTE 1 




NOT USED 






DATA BYTE 2 










• 
• 
• 


COUNT 


DATA BYTE 1 








DATA BYTE 2 






DATA BYTE N-1 




• 
• 
• 




255 


DATA BYTE N 








NOT USED 




DATA BYTE N-1 




511 


511 


DATA BYTE N 




N = DATA PACKET LENGTH 




SID = SOURCE ID 








DID = DESTINATION ID 








(DID = FOR BROADCASTS) 






FIGURE 8 - RAM BUFFER PACKET CONFIGURATION 
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size is specified in the "Define Configuration" 
command. When long packets are enabled, the 
COM20020 interprets the packet as either a 



Command Chaining operation, please see the 
Command Chaining section for further detail on 
the transmit sequence. Once the TA bit 



ong or shor 



packe 



, depending ort wh 
buffer address 2 contains a zero or non-zero 
value. The format of the buffer is shown in 
Figure 7. Address contains the Source 
Identifier (SID); Address 1 contains the 
Destination Identifier (DID); Address 2 (COUNT) 
contains, for short packets, the value 256-N, 
where N represents the message length, or for 
long packets, the value 0, indicating that it is 
indeed a long packet. In the latter case, 
Address 3 (COUNT) would contain the value 
51 2-N, where N represents the message length. 
The SID in Address is used by the receiving 
node to reply to the transmitting node. The 
COM20020 puts the local ID in this location, 
therefore it is not necessary to write into this 
location. 

Please note that a short packet may contain 
between 1 and 253 data bytes, while a long 
packet may contain between 257 and 508 data 
bytes. A minimum value of 257 exists on a 
long packet so that the COUNT is expressable 
in eight bits. This leaves three exception packet 
lengths which do not fit into either a short or 
long packet; packet lengths of 254, 255, or 
256 bytes. If packets of these lengths must be 
sent, the user must add dummy bytes to the 
packet (00's) in order to make the packet fit 
into a long packet. 

Once the buffer is written into, the 
microcontroller awaits a logic " 1 " on the TA bit, 
indicating that a previous transmit command 
has concluded and another may be issued. 
Each time the message is loaded and a transmit 
command issued, it will take a variable amount 
of time before the message is transmitted, 
depending on the traffic on the network and the 
location of the token at the time the transmit 
command was issued. Typically, the conclusion 
of the transmit command, which is flagged 
when TA becomes a logic "1", generates an 
interrupt. If the device is configured for the 




Decome! a flflIU I , n 
the " Enable Transmit from Page f nn" command, 
which resets the TA and TMA bits to logic "0". 
If the message is not a BROADCAST, the 
COM20020 automatically issues a FREE 
BUFFER ENQUIRY to the destination node in 
order to send the message. At this point, one 
of four possibilities may occur. 

The first possibility is if a free buffer is available 
at the destination node, in which case it 
responds with an ACKnowledgement. At this 
point, the COM20020 fetches the data from the 
Transmit Buffer and performs the transmit 
sequence, (f a successful transmit sequence is 
completed, the TMA bit and the TA bit are set 
to logic " 1 ". If the packet was not transmitted 
successfully, TMA will not be set. A successful 
transmission occurs when the receiving node 
responds to the packet with an ACK. An 
unsuccessful transmission occurs when the 
receiving node does not respond to the packet. 

The second possibility is if the destination node 
responds to the Free Buffer Enquiry with a 
Negative AcKnowledgement. A NAK occurs 
when the Rl bit of the destination node is a 
logic "1". In this case, the token is passed on 
from the transmitting node to the next node. 
The next time the transmitter receives the 
token, it will again transmit a FREE BUFFER 
ENQUIRY. If a NAK is again received, the token 
is again passed onto the next node. The 
Excessive NAK bit of the Diagnostic Status 
Register is used to prevent an endless loop of 
FBE's and NAK's. If no timeout existed, the 
transmitting node would continue issuing a Free 
Buffer Enquiry, even though it would 
continuously receive a NAK as a response. The 
EXCNAK bit generates an interrupt (if enabled) 
in order to tell the microcontroller to disable the 
transmitter via the "Disable Transmitter" 
command. This causes the transmission to be 
abandoned and the TA bit to be set to a logic 
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"1" when the node next receives the token, 
while the TMA bit remains at a logic "0". 
Please refer to the Improved Diagnostics section 
for further detail on the EXCNAK bit. 

The third possibility which may occur after a 
FREE BUFFER ENQUIRY is issued is if the 
destination node does not respond at all. In this 
case, the TA bit is set to a logic "1 ", while the 
TMA bit remains at a logic "0". The user 
should determine whether the node should try 
to reissue the transmit command. 

The fourth possibility is if a non-traditional 
response is received (some pattern other than 
ACK or NAK, such as noise). In this case, the 
token is not passed onto the next node, which 
causes the Lost Token Timer of the next node 
to time out, thus generating a network 
reconfiguration. 

The "Disable Transmitter" command may be 
used to cancel any pending transmit command 
when the COM20020 next receives the token. 
Normally, in an active network, this command 
will set the TA status bit to a logic " 1 " when 
the token is received. If the "Disable 
Transmitter" command does not cause the TA 
bit to be set in the time it takes the token to 
make a round trip through the network, one of 
three situations exists. Either the node is 
disconnected from the network, or there are no 
other nodes on the network, or the external 
receive circuitry has failed. These situations 
can be determined by either using the improved 
diagnostic features of the COM20020 or using 
another software timeout which is greater than 
the worst case time for a round trip token pass, 
which occurs when all nodes transmit a 
maximum length message. 

Receive Sequence 

A receive sequence begins with the Rl status bit 
becoming a logic "1", which indicates that a 
previous reception has concluded. The 
microcontroller will be interrupted if the 



corresponding bit in the Interrupt Mask Register 
is set to logic " 1 " . Otherwise, the 
microcontroller must periodically check the 
Status Register. Once the microcontroller is 
alerted to the fact that the previous reception 
has concluded, it may issue the "Enable Receive 
to Page fnn" command, which resets the Rl bit 
to logic "0" and selects a new page in the RAM 
buffer. Again, the appropriate buffer size is 
specified in the "Define Configuration" 
command. Typically, the page which just 
received the data packet will be read by the 
microcontroller at this point. 

Once the "Enable Receive to Page fnn" 
command is issued, the microcontroller attends 
to other duties. There is no way of knowing 
how long the new reception will take, since 
another node may transmit a packet at any 
time. When another node does transmit a 
packet to this node, and if the "Define 
Configuration" command has enabled the 
reception of long packets, the COM 20020 
interprets the packet as either a long or short 
packet, depending on whether the content of 
the buffer location 2 is zero or non-zero. The 
format of the buffer is shown in Figure 8. 
Address contains the Source Identifier (SID), 
Address 1 contains the Destination Identifier 
(DID), and Address 2 contains, for short 
packets, the value 256-N, where N represents 
the message length, or for long packets, the 
value 0, indicating that it is indeed a long 
packet. In the latter case, Address 3 contains 
the value 512-N, where N represents the 
message length. Note that on reception, the 
COM 20020 deposits packets into the RAM 
buffer in the same format that the transmitting 
node arranges them, which allows for a 
message to be received and then retransmitted 
without rearranging any bytes in the RAM 
buffer other than the SID and DID. Once the 
packet is received and stored correctly in the 
selected buffer, the COM20020 sets the Rl bit 
to logic "1" to signal the microcontroller that 
the reception is complete. 
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FIGURE 9 - COMMAND CHAINING STATUS REGISTER 



COMMAND CHAINING 

The Command Chaining operation allows 
consecutive transmissions and receptions to 
occur without host intervention. Through the 
use of a dual two-level FIFO, commands to be 
transmitted and received, as well as the status 
bits, are pipelined. 

In order for the COM20020 to be compatible 
with previous SMC ARCNET devices, the device 
defaults to the non-chaining mode. In order to 
take advantage of the Command Chaining 
operation, the Command Chaining Mode must 
be enabled via a logic "1" on bit 6 of the 
Configuration Register. 

In Command Chaining, the Status Register 
appears as in Figure 9. 

The following is a list of Command Chaining 
guidelines for the software programmer to 
follow. Further detail can be found in the 
Transmit Command Chaining and Receive 
Command Chaining sections. 

• The device is designed such that the interrupt 
service routine latency does not affect 
performance. 

• Up to two outstanding transmissions and two 
outstanding receptions can be pending at any 
given time. The commands may be given in 
any order. 



• Up to two outstanding transmit interrupts 
and two outstanding receive interrupts are 
stored by the device, along with their 
respective status bits. 

• The Interrupt Mask bits act on TTA (Rising 
Transition on Transmitter Available} for 
transmit operations and TRI (Rising 
Transition of Receiver Inhibited) for receive 
operations. TTA is set upon completion of 
a packet transmission only. TRI is set 
upon completion of a packet reception 
only. Typically there is no need to mask 
the TTA and TRI bits after clearing the 
interrupt. 

• The traditional TA and Rl bits are still 
available to reflect the present status of 
the device. 

Transmit Command Chaining 

When the processor issues the first "Enable 
Transmit to Page fnn" command, the 
COM20020 responds in the usual manner by 
resetting the TA and TMA bits to prepare for 
the transmission from the specified page. The 
TA bit can be used to see if there is currently a 
transmission pending, but the TA bit is really 
meant to be used in the non-chaining mode 
only. The TTA bits provide the relevant 
information for the device in the Command 
Chaining mode. 
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In the Command Chaining Mode, at any time 
after the first command is issued, the processor 
can issue a second "Enable Transmit from Page 
fnn" command. The COM20020 stores the fact 
that the second transmit command was issued, 
along with the page number. 

After the first transmission is completed, the 
COM20020 updates the Status Register by 
setting the TTA bit, which generates an 
interrupt. The interrupt service routine should 
read the Status Register. At this point, the TTA 
bit will be found to be a logic " 1 " and the TMA 
(Transmit Message Acknowledge) bit will tell 
the processor whether the transmission was 
successful. After reading the Status Register, 
the "Clear Transmit Interrupt" command is 
issued, thus resetting the TTA bit and clearing 
the interrupt. Note that only the "Clear 
Transmit Interrupt" command will clear the TTA 
bit and the interrupt. It is not necessary, 
however, to clear the bit or the interrupt right 
away because the status of the transmit 
operation is double buffered in order to retain 
the results of the first transmission for analysis 
by the processor. This information will remain 
in the Status Register until the "Clear Transmit 
Interrupt" command is issued. Note that the 
interrupt will remain active until the command is 
issued, and the second interrupt will not occur 
until the first interrupt is acknowledged. The 
COM20020 guarantees a minimum of 200nS 
interrupt inactive time interval between 
interrupts. The TMA bit is also double buffered 
to reflect whether the appropriate transmission 
was a success. The TMA bit should only be 
considered valid after the corresponding TTA bit 
has been set to a logic "1 ". The TMA bit never 
causes an interrupt. 

When the token is received again, the second 
transmission will be automatically initiated after 
the first is completed by using the stored 
"Enable Transmit from Page fnn" command. The 
operation is as if a new "Enable Transmit from 
Page fnn" command has just been issued. After 
the first Transmit status bits are cleared, the 



Status Register will again be updated with the 
results of the second transmission and a second 
interrupt resulting from the second transmission 
will occur. The COM20020 guarantees a 
minimum of 200ns interrupt inactive time 
interval before the following edge. 

The Transmitter Available (TA) bit of the 
Interrupt Mask Register now masks only the 
TTA bit of the Status Register, not the TA bit 
as in the non-chaining mode. Since the TTA bit 
is only set upon transmission of a packet (not 
by RESET), and since the TTA bit may easily be 
reset by issuing a "Clear Transmit Interrupt" 
command, there is no need to use the TA bit of 
the Interrupt Mask Register to mask interrupts 
generated by the TTA bit of the Status Register. 

In Command Chaining mode mode, the "Disable 
Transmitter" command will cancel the oldest 
transmission. This permits canceling a packet 
destined for a node not ready to receive. If 
both packets should be canceled, two "Disable 
Transmitter" commands should be issued. 

Receive Command Chaining 

Like the Transmit Command Chaining operation, 
the processor can issue two consecutive 
"Enable Receive from Page fnn" commands. 

After the first packet is received into the first 
specified page, the TRI bit of the Status 
Register will be set to logic "1", causing an 
interrupt. Again, the interrupt need not be 
serviced immediately. Typically, the interrupt 
service routine will read the Status Register. At 
this point, the Rl bit will be found to be a logic 
"1". After reading the Status Register, the 
"Clear Receive Interrupt" command should be 
issued, thus resetting the TRI bit and clearing 
the interrupt. Note that only the "Clear Receive 
Interrupt" command will clear the TRI bit and 
the interrupt. It is not necessary, however, to 
clear the bit or the interrupt right away because 
the status of the receive operation is double 
buffered in order to retain the results of the first 
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reception for analysis by the processor, 
therefore the information will remain in the 
Status Register until the "Clear Receive 

r 





S as 

interrupt will remain active until the "Clear 
Receive Interrupt" command is issued, and the 
second interrupt will be stored until the first 
interrupt is acknowledged. A minimum of 
200nS interrupt inactive time interval between 
interrupts is guaranteed. 

The second reception will occur as soon as a 
second packet is sent to the node, as long as 
the second "Enable Receive to Page fnn" 
command was issued. The operation is as if a 
new "Enable Receive to Page fnn" command 
has just been issued. After the first Receive 
status bits are cleared, the Status Register will 
again be updated with the results of the second 
reception and a second interrupt resulting from 
the second reception will occur. 

In the COM20020, the Receive Inhibit (Rl) bit of 
the Interrupt Mask Register now masks only the 
TRI bit of the Status Register, not the Rl bit as 
in the non-chaining mode. Since the TRI bit is 
only set upon reception of a packet (not by 
RESET), and since the TRI bit may easily be 
reset by issuing a "Clear Receive Interrupt" 
command, there is no need to use the Rl bit of 
the Interrupt Mask Register to mask interrupts 
generated by the TRI bit of the Status Register. 

In Command Chaining mode, the "Disable 
Receiver" command will cancel the oldest 
reception, unless the reception has already 
begun. If both receptions should be canceled, 
two "Disable Receiver" commands should be 
issued. 



RESET DETAILS 
Internal Reset Logic 



The COM20020 includes special reset circuitry 
to guarantee smooth operation during reset. 
Special care is taken to assure proper operation 
in a variety of systems and modes of operation. 
The COM20020 contains di gital filter circuitry 
and a Schmitt Trigger on the RESET IN signal to 
reject glitches in order to ensure fault-free 
operation. 

The COM20020 supports two reset options; 
software and hardware reset. A software reset 
is generated when a logic "1" is written to bit 
7 of the Configuration Register. The device 
remains in reset as long as this bit is set. The 
software reset does not affect the 
microcontroller interface modes determined 
after hardware reset, nor does it affect the 
contents of the Address Pointer Registers, the 
Configuration Register, or the Setup Register. 
A hardware reset occurs when a low signal is 
asserted on the RESET IN input. The minimum 
reset pulse width is 3.2/ys. This pulse width is 
used by the internal digital filter, which filters 
short glitches to allow only valid resets to 
occur. 

Upon reset, the transmitter portion of the 
device is disabled and the internal registers 
assume those states outlined in the Internal 
Registers section. 



After the RESET IN signal is removed the user 
may write to the internal registers. Since 
writing a non-zero value to the Node ID Register 
wakes up the COM2002O core, the Setup 
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Register should be written before the Node ID 
Register. Once the Node ID Register is written 
to, the COM20020 reads the value and 
executes two write cycles to the RAM buffer. 
Address is written with the data D1H and 
address 1 is written with the Node ID. The data 
pattern D1H was chosen arbitrarily, and is 
meant to provide assurance of proper 
microsequencer operation. 

INITIALIZATION SEQUENCE 

When the COM20020 is powered on the 
internal registers may be written to. Since 
writing a non-zero value to the Node ID Register 
wakes up the core, the Setup Register should 
be written to before the Node ID Register. Until 
a non-zero value is placed into the NID Register, 
no microcode is executed, no tokens are passed 
by this node, and no reconfigurations are 
generated by this node. Once a non-zero value 
is placed in the register, the core wakes up, but 
the node will not attempt to join the network 
until the TX Enable bit of the Configuration 
Register is set. 

Before setting the TX Enable bit, the software 
may make some determinations. The software 
may first observe the Receive Activity and the 
Token Seen bits of the Diagnostic Status 
Register to verify the health of the receiver and 
the network. 

Next, the uniqueness of the Node ID value 
placed in the Node ID Register is determined. 
The TX Enable bit should still be a logic "0" 
until it is ensured that the Node ID is unique. If 
this node ID already exists, the Duplicate ID bit 
of the Diagnostic Status Register is set after a 
maximum of 840mS (or 1 680mS if the ET1 and 
ET2 bits are other than 1,1). To determine if 
another node on the network already has this 
ID, the COM20020 compares the value in the 
Node ID Register with the DID's of the token, 
and determines whether there is a response to 
it. Once the Diagnostic Status Register is read, 



the DUPID bit is cleared. The user may then 
attempt a new ID value, wait 840mS before 
checking the Duplicate ID bit, and repeat the 
process until a unique Node ID is found. At this 
point, the TX Enable bit may be set to allow the 
node to join the network. Once the node joins 
the network, a reconfiguration occurs, as usual, 
thus setting the MYRECON bit of the Diagnostic 
Status Register. 

The Tentative ID Register may be used to build 
a network map of all the nodes on the network, 
even once the COM20020 has joined the 
network. Once a value is placed in the 
Tentative ID Register, the COM20020 looks for 
a response to a token whose DID matches the 
Tentative ID Register. The software can record 
this information and continue placing Tentative 
ID values into the register to continue building 
the network map. A complete network map is 
only valid until nodes are added to or deleted 
from the network. Note that a node cannot 
detect the existence of the next logical node on 
the network when using the Tentative ID. To 
determine the next logical node, the software 
should read the Next ID Register. 

IMPROVED DIAGNOSTICS 

The COM20020 allows the user to better 
manage the operation of the network through 
the use of the internal Diagnostic Status 
Register. 

A high level on the My Reconfiguration 
(MYRECON) bit indicates that the Token 
Reception Timer of this node expired, causing a 
reconfiguration by this node. After the 
Reconfiguration (RECON) bit of the Status 
Register interrupts the microcontroller, the 
interrupt service routine will typically read the 
MYRECON bit of the Diagnostic Status Register. 
Reading the Diagnostic Status Register resets 
the MYRECON bit. Successive occurrences of 
a logic "1 " on the MYRECON bit indicates that 
a problem exists with this node. At that point, 
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the transmitter should be disabled so that the 
entire network is not held down while the node 
is being evaluated. 



MYRECON = 0. DUPID = Q, RCVACT=1. 
TXEN = 0. TOKEN = 1 : Single node network. 



The Duplicate ID (DUPID) bit is used before the 
node joins the network to ensure that another 
node with the same ID does not exist on the 
network. Once it is determined that the ID in 
the Node ID Register is unique, the software 
should write a logic "1" to bit 5 of the 
Configuration Register to enable the basic 
transmit function. This allows the node to join 
the network. 

The Receive Activity (RCVACT) bit of the 
Diagnostic Status Register will be set to a logic 
" 1 " whenever activity (logic " 1 ") is detected on 
the RXIN pin. 

The Token Seen (TOKEN} bit is set to a logic 
" 1 " whenever any token has been seen on the 
network (except those tokens transmitted by 
this node). 

The RCVACT and TOKEN bits may help the user 
to troubleshoot the network or the node. If 
unusual events are occurring on the network, 
the user may find it valuable to use the TXEN 
bit of the Configuration Register to qualify 
events. Different combinations of the RCVACT, 
TOKEN, and TXEN bits, as shown indicate 
different situations: 

Normal Results: 

RCVACT = 1 . TOKEN = 1 . TXEN - 0: The node 
is not part of the network. The network is 
operating properly without this node. 

RCVACT = 1 . TOKEN = 1 . TXEN = 1 : The node 
sees receive activity and sees the token. The 
basic transmit function is enabled. Network and 
node are operating properly. 



Abnormal Results: 

RCVACT =1. TOKEN =0. TXEN = X: The node 
sees receive activity, but does not see the 
token. Either no other nodes exist on the 
network, some type of data corruption exists, 
the media driver is malfunctioning, the topology 
is set up incorrectly, there is noise on the 
network, or a reconfiguration is occurring. 

RCVACT = 0. TOKEN =0. TXEN = 1 : No receive 
activity is seen and the basic transmit function 
is enabled. The transmitter and/or receiver are 
not functioning properly. 

RCVACT = 0. TOKEN = 0. TXEN = 0: No receive 
activity and basic transmit function disabled. 
This node is not connected to the network. 

The Excessive NAK (EXCNAKJ bit is used to 
replace a timeout function traditionally 
implemented in software. This function is 
necessary to limit the number of times a sender 
issues a FBE to a node with no available buffer. 
When the destination node replies to 1 28 FBEs 
with 1 28 NAKs or 4 FBEs with 4 NAKs, the 
EXCNAK bit of the sender is set, generating an 
interrupt. At this point the software may 
abandon the transmission via the "Disable 
Transmitter" command. This sets the TA bit to 
logic "1" when the node next receives the 
token, to allow a different transmission to 
occur. The timeout value for the EXNACK bit 
(128 or 4} is determined by the FOUR-NAKS bit 
on the Setup Register. 

The user may choose to wait for more NAK's 
before disabling the transmitter by taking 
advantage of the wraparound counter of the 
EXCNAK bit. When the EXCNAK bit goes high, 
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indicating 128 or 4 NAKs, the "POR Clear 
Flags" command may be issued to reset the bit 
so that it will go high again after another count 
of 128 or 4. The software may count the 
number of times the EXCNAK bit goes high, and 
once the final count is reached, the "Disable 
Transmitter" command may be issued. 

The New Next ID bit permits the software to 
detect the withdrawal or addition of nodes to 
the network. 

The Tentative ID bit allows the user to build a 
network map of those nodes existing on the 
network. This feature is useful because it 
minimizes the need for human intervention. 
When a value placed in the Tentative ID 
Register matches the Node ID of another node 
on the network, the TENTID bit is set, telling 
the software that this NODE ID exists. The 
software should periodically place values in the 
Tentative ID Register and monitor the New Next 
ID bit to maintain an updated network map. 



OSCILLATOR 

The COM20020 contains circuitry which, in 
conjunction with an external parallel resonant 
crystal or TTL clock, forms an oscillator. 

If an external crystal is used, two capacitors are 
needed (one from each leg of the crystal to 
ground}. No external resistor is required, since 
the COM20020 contains an internal resistor. 
The crystal must have an accuracy of 0.020% 
or better. 

The XTAL2 side of the crystal may be loaded 
with a single 74HC-type buffer in order to 
generate a clock for other devices. 

The user may attach an external TTL clock, 
rather than a crystal, to the XTAL1 signal. In 
this case, a 3900. pull-up resistor is required on 
XTAL1, while XTAL2 should be left 
unconnected. 
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OPERATIONAL DESCRIPTION 
MAXIMUM GUARANTEED RATINGS" 



Operating Temperature Range 0°C to +70°C 

Storage Temperature Range -55°C to + 1 50°C 

Lead Temperature (soldering, 10 seconds) +325°C 

Positive Voltage on any pin, with respect to ground V DD + 0.3V 

Negative Voltage on any pin, with respect to ground -0.3V 

Maximum V D0 +7V 



* Stresses above those listed may cause permanent damage to the device. This is a stress rating 
only and functional operation of the device at these or any other condition above those indicated 
in the operational sections of this specification is not implied. 

NOTE: When powering this device from laboratory or system power supplies, it is important that the 
Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies 
exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on or off. In 
addition, voltage transients on the AC power line may appear on the DC output. If this possibility 
exists it is suggested that a clamp circuit be used. 



DC ELECTRICAL CHARACTERISTICS V DO = 5.0V±10% 
COM20020: T A =0°C to +70°C, COM20020I: T A = -40°C to +85°C 



PARAMETER 


SYMBOL 


MIN 


TYP 


MAX 


UNIT 


COMMENT 


Low Input Voltage 1 


v, L1 






0.8 


V 


TTL Levels 


(All inputs except A2, 














XTAL1, RESET, RD, 














WR, and RXIN) 














High 


V.H1 


2.0 






V 


TTL Levels 


High Input Voltage 1 














(All inputs except A2, 














XTAL1 , RESET, RD, 














WR, and RXIN) 














Low input Voltage 2 


v IL2 






1.0 


V 


TTL Clock Input 


(XTAL1 ) 














High Input Voltage 2 


v,„ 2 


4.0 






V 




(XTAL1) 














Low to High Threshold 


V 1L „ 




1.8 




V 


Schmitt Trigger, 


Input Voltage (A2, 












All Values at V^ = 


RESET, RD, WR, RXIN) 












5V 


High to Low Threshold 


V IHL 




1.2 




V 




Input Voltage (A2, 














RESET, RD, WR, RXIN) 
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PARAMETER 


SYMBOL 


MIN 


TYP 


MAX 


UNIT 


COMMENT 


Low Output Voltage 1 
(PULSE1 in Normal 
Mode, PULSE2, 
TXEN) 

High Output Voltage 1 
{PULSE1 in Normal 
Mode, PULSE2, 
TXEN) 


Vol, 
Vohi 


2.4 




0.4 


V 
V 


l SINK = 4mA 
'source = "2mA 


Low Output Voltage 2 
(D0-D7) 

High Output Voltage 2 
(DO-D7) 


V<>L2 
V()H2 


2.4 




0.4 


V 
V 


l SINK = 16mA 
'source = 2mA 


Low Output Voltage 3 
(INTR) 

High Output Voltage 3 
(INTR) 


VOL3 
V(>H3 


2.4 




0.8 


V 
V 


'sink = 24mA 
•source = -10mA 


Low Output Voltage 4 
{PULSE1 in Backplane 
Mode - Open Drain) 


VOL4 






0.5 


V 


•sink = 48mA 

Onpn Drain Drivpr 


Dynamic V 00 Supply 
Current 1 


'doi 






50 


mA 




Input Pull-up Current 
{PULSE1 in Backplane 
Mode, A1, AD0-AD2, 
D3-D7) 

Input Leakage Current 
(All inputs except A1, 
AD0-AD2, D3-D7, 
XTAL1, XTAL2) 


Ip 




80 


200 
± 10 


l/A 
//A 


v 1N =o.ov 

Vss < V w < V,,,, 
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CAPACITANCE (T A = 25°C; f c = 1MHz; = OV) 
Output and I/O pins capacitive load specified as follows: 



PAR 



Yl 




Input Capacitance 



5.0 



PF 



Output Capacitance 1 
(All outp uts except 
PULSE 1 in Backplane 
Mode) 

Output Ca pacitance 2 
(PULSE 1 , in Backplane 
Mode Only - Open 
Drain) 



45 



400 



PF 



PF 



Maximum 
Capacitive Load 
which can be 
supported by each 
output. 



AC Measurements are taken at the following points: 

Inputs: Outputs: 

— t -i 



2.4V 
1.4V 
0.4V 



— t 




50% 



— t 



50% 



2.0V 



0.8V 



2.0V 



0.8V 



— t 



Inputs are driven at 2.4V tor logic "1" and 0.4 V for logic "0". 

Outputs are measured at 2.0V min. for logic "1" and 0.8V max. for logic "0". 
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AD0-AD2, 

na-r> 7 r 



VALID 



cs 

ALE 
DS 

DIR 




t2, 
t4 



t3 



V 



J5: 



t6 r* 



VALID DATA 



r 



17 K 



ta 



no 





Parameter 


min 


max 


units 


t1 


Address Setup to ALE Low 


30 




nS 


t2 


Address Hold from ALE Low 


10 




nS 


t3 


CS Setup to ALE Low 


10 




nS 


t4 


CS Hold from ALE Low 


20 




nS 


t5 


ALE Low to DS Low 


15 




nS 


t6 


DS Low to Valid Data 




40 


nS 


t7 


DS High to Data High Impedance 





20 


nS 


t8 


Cycle Time (DS Low to Next Time Low) 


4T* 




nS 


t9 


DIR Setup to DSActfve 


10 




nS 


t10 


DIR Hold from DS Inactive 


10 




nS 



* T is the Arbitration Clock Period. 
T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 



Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 



FIGURE 10 • MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; READ CYCLE 
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AD0-AD2, 
D3-D7 






Parameter 


min 


max 


units 


t1 


Address Setup to ALE Low 


30 




nS 


t2 


Address Hold from ALE Low 


10 




nS 


t3 


CS Setup to ALE Low 


10 




nS 


t4 


CS Hold fromALE Low 


20 




nS 


t5 


ALE Low to RD Low 


15 




nS 


t6 


RD Low to Valid Data 




40 


nS 


t7 


RD High to Data High Impedance 





20 


nS 


t8 


Cycle Time (RD Low to Next Time Low) 


4T* 




nS 



* T is the Arbitration Clock Period. 
T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 



FIGURE 10A - MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; READ CYCLE 
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cs 



ALE 



DS 



DIR 






Parameter 


min 


max 


units 


t1 


Address Setup to ALE Low 


30 




nS 


t2 


Address Hold from ALE Low 


10 




nS 


t3 


CS Setup to ALE Low 


10 




nS 


t4 


CS Hold from ALE Low 


20 




nS 


t5 


ALE Low to DS Low 


15 




nS 


t6 


Valid Data Setup to DS High 


30 




nS 


t7 


Data Hold from DS High 


10 




nS 


t8 


Cycle Time (DS Low to Next Time Low)" 


4T* 




nS 


t9 


DIR Setup to DS Active 


10 




nS 


no 


DIR Hold from DS Inactive 


10 




nS 



* T is the Arbitration Clock Period. 
T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 

** Note 2: Any cycle occurring after a write to Address Pointer Low Register requires a 
minimum of 4T from the trailing edge of DS to the leading edge of the 
next DS. 



FIGURE 11 - MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; WRITE CYCLE 
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Parameter 


min 


max 


units 


t1 


Address Setup to ALE Low 


30 




nS 


t2 


Address Hold from ALE Low 


10 




nS 


t3 


CS Setup to ALE Low 


10 




nS 


t4 


CS Hold from ALE Low 


20 




nS 


t5 


ALE Low to WR Low 


15 




nS 


t6 


Valid Data Setupjo WR High 


30 




nS 


t7 


Data Hold from WR High 


10 




nS 


t8 


Cycle Time (WR Low to Next Time Low)** 


4T* 




nS 



* T is the Arbitration Clock Period. 
T Is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 

" Note 2: Any cycle occurring after a write to Add ress Pointer Low Register requires a 
minimum of 4T from the trailing edge of WR to the leading edge of the 
nextWR. 



FIGURE 11 A - MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; WRITE CYCLE 
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A0-A2 



CS 



RD 



D0-D7 



t3 



VALID 



t5 




VALID DATA 



J 



r 



V 



*»17 I-*- 



> 





Parameter 


min 


max 


units 


t1 


Address Setup to RD Active 


15 




nS 


t2 


Address Hold from RD inactive 


10 




nS 


t3 


CS Setup to RD Active 


5" 




nS 


t4 


CS Hold from RD Inactive 







nS 


t5 


Cycle Time (RD Low to Next Time Low) 


4T* 




nS 


t6 


RD Low to Valid Data 




40 


nS 


t7 


RD High to Data High Impedance 





20 


nS 



* T is the Arbitration Clock Period. 

T is identical to XTAL1 if SLOW ARB = 0, 

T is twice XTAL1 period if SLOW ARB = 1 
** CS may become active after control becomes active, but the access time 

will now be 45nS measured from the leading edge of CS. 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 



FIGURE 12 - NON-MULTiPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; READ CYCLE 
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A0-A2 
CS 

DIR 
DS 

D0-D7 






Parameter 


min 


max 


units 


t1 


Address Setup to DS Active 


15 




nS 


M 


Address Hold from DS Inactive 


10 




nS 


t3 


CS Setup to DS Active 


5" 




nS 


t4 


CS Hotd from D~S Inactive 







nS 


t5 


DIR Setup to DS Active 


10 




nS 


t6 


Cycle Time (DS Low to Next Time Low) 


4T* 




nS 


t7 


DIR Hold from DS Active 


10 




nS 


t8 


DS Low to Valid Data 




40 


nS 


t9 


DS High to Data High Impedence 





20 


nS 



* T is the Arbitration Clock Period. 

T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

** CS may become active after control becomes active, but the access time will 
now be 45nS measured from the leading edge of CS. 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 



FIGURE 12A - NON-MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; READ CYCLE 
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A0-A2 



CS 



WR 



D0-D7 




VALID DATA 





Parameter 


min 


max 


unrts 


t1 


Address Setup to WR Active 


15 




nS 


t2 


Address HoldJrom WR Inactive 


10 




nS 


t3 


CS Setup to WR Active 


5 




nS 


t4 


CS Hold fromWR inactive 







nS 


t5 


Cycle Time (WR Low to Next Time Low)** 


4T* 




nS 


16 


Valid Data Setupjo WR High 


30" 




nS 


t7 


Data Hold from WR High 


10 




nS 



* T is the Arbitration Clock Period. 
T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

"CS may become active after control becomes active, but the data setup time will now 
be 30 nS measured from the later of CS falling or Valid Data available. 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 

Note 2: Any cycle occurring after a write to the Address Pointer Low Register 

requires a minimum of 4T from the trailing edge of WR to the leading edge 
of the next WR. 



FIGURE 13 - NON-MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; WRITE CYCLE 
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A0-A2 

CS 
DIR 

DS 

D0-D7 



k- ti 



VALID 



t3 



t5 



t6 




t8 



, t6" 

t9 



VALID DATA 



XXXXX) 





Parameter 


min 


max 


units 


t1 


Address Setup to DS Active 


15 




nS 


t2 


Address Hold from DS Inactive 


10 




nS 


t3 


CS Setup to DS Active 


5 




nS 


t4 


CS Hold from DS Inactive 







nS 


t5 


DIR Setup to DS Active 


10 




nS 


t6 


Cycle Time (DS Low to Next Time Low)** 


4T* 




nS 


t7 


DIR Hold from DS Inactive 


10 




nS 


t8 


Valid Data Setup to DS High 


30** 




nS 


t9 


Data Hold from DS High 


10 




nS 



* T is the Arbitration Clock Period. 
T is identical to XTAL1 if SLOW ARB = 0, 
T is twice XTAL1 period if SLOW ARB = 1 

**CS may become active after control becomes active, but the data setup time will 
now be 30 nS measured from the later of CS falling or Valid Data available. 

Note 1 : The Microcontroller typically accesses the COM20020 on every other cycle. 
Therefore, the cycle time specified in the microcontroller's datasheet 
should be doubled when considering back-to-back COM20020 cycles. 

Note 2: Any cycle occurring after a write to the Address Pointer Low Register 
requires a minimum. of 4T from the trailing edge of DS to the leading 
edge of the next DS. 



FIGURE 13A- NON-MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; WRITE CYCLE 
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TXEN 



PULSE 1 



t4 



PULSE2 



/ 



t2 



-t5- 



7 



— ► 

-ss— 



t2 



— LAST BIT 
(400 nS BIT TIME) 

► 



■sv 

-SV- 



RXIN 



t6 



t7 



Parameter 



min 


typ 


max 


units 




100 • 




nS 




400 * 




nS 


-10 





+10 


nS 


850 




950 


nS 


250 




350 


nS 

_____ 


10 


100* 








400 * 




nS 



t1 

t2 
t3 
t4 
t5 

IT 
t7 



PULSE1 . PULSE2 Pulse Width 
PULSE1 , PULSE2 Period 
PULSE 1, PU LSE2 Ove rlap 
TX_H Low to PULSE1 Low" 



Beginning of Last Bit Time to TXEN 
RXIN Pulse Width 
RXIN Period 



* t1 = 2 x (crystal period) for clock frequencies other than 20 MHz. 

* t2,t7 = 8 x (crystal period) for clock frequencies other than 20 MHz. 

This period applies to data of two consecutive one's. 
" t4: For clock frequencies other than 20 MHz, t4 = 18 x (crystal period)* 50 nsec. 
" t5: For clock frequencies other than 20 MHz, t5 = 6 x (crystal period)*. 50 nsec. 



FIGURE 14 - NORMAL MODE TRANSMIT OR RECEIVE TIMING 
(These signals are to and from the hybrid) 
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Parameter 


min 


typ 


max 


units 


t1 


PULSE2 High to TXEN Low 







50 


nS 


t2 


PULSE1 Pulse Width 




200* 




nS 


t3 


PULSE1 Period 




400* 




nS 


t4 


PULSE2 Low to PULSE1 Low 







50 


nS 


t5 


PULSE2 HiQh Time 




100* 




nS 


t6 


PULSE2 Low Time 




100* 




nS 


t7 


PULSE2 Period 




200* 




nS 


t8 


PULSE2 Hiah to TXEN High 







50 


nS 




(First rising edge on PULSE2 after Last Bit Time) 










t9 


TXEN Low to first PULSE1 Low" 


650 




750 


nS 


no 


RXIN Pulse Width 


10 


200* 




nS 


t11 


P.XIN Period 




400* 




nS 



* t5,t6 = 2 x (crystal period) for clock frequencies other than 20 MHz. 

* t2,t7,t1 = 4 x (crystal period) for clock frequencies other than 20 MHz. 

* t3,t1 1 = 8 x (crystal period) for clock frequencies other than 20 MHz. 

This period applies to data of two consecutive one's. 
** t9: For clock frequencies other than 20 MHz, t9 = 14 x (clock perk)d)±_50 nsec. 



FIGURE 15 - BACKPLANE MODE TRANSMIT OR RECEIVE TIMING 
(These signals are to and from the differential driver or the cable) 
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XTAL1 



r 



t1 



t2 



t3 



r 





Parameter 


min 


typ 


max 


units 


t1 


Input Clock High Time 


20 






nS 


t2 


Input Clock Low Time 


20 






nS 


t3 


Input Clock Period 


50 




100 


nS 


t4 


Input Clock Frequency 


10 




20 


MHz 



FIGURE 16 - TTL INPUT TIMING ON XTAL1 PIN 



RESET IN 



t1 



INTR 



t2 





Parameter 


min 


typ 


max 


units 


t1 


RESET IN Pulse Width 


3.2 






uS 


t2 


INTR High to Next INTR Low 


200 






nS 



FIGURE 17 - RESET AND INTERRUPT TIMING 
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DIM 


28L 


A 


.160-.180 


A1 


.090-.120 


B 


.013-.021 


B1 


.026-.032 


C 


.020-.045 


D 


.485-.49S 


D1 


.450-.456 


D2 


.390-.430 


D3 


.300 REF 


E 


.050 BSC 


F 


.042-.056 


G 


.042-.048 


J 


.000-.020 


R 


.025-.045 



NOTES: 

1 . All dimensions are in inches. 

2. Circle indicating pin 1 can appear on a top surface as shown on the drawing or 
right above it on a beveled edge. 

FIGURE 18 - 28-PIN PLCC PACKAGE DIMENSIONS 
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Seating 
Plane 



DIM 


24L 


A 


.090-.150 


A1 


.020-.065 


A2 


.145-.155 


B 


.016-.021 


B1 


.060-.070 


C 


.010-.014 


D 


1.245-1.265 


E 


.590-.630 


E1 


.530-.545 


e 


.100 BSC 


eA 


.600REF 


eB 


.610-.670 


L 


.120-.140 


S 


.065-.085 



Note: All dimensions are in inches. 



FIGURE ISA - 24-PIN DIP PACKAGE DIMENSIONS 
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Circuit diagrams utilizing SMC products are included at a means of illustrating typical 
applications; consequently complete information sufficient for construction purposes 
is not necessarily given. The information has been carefully checked and is believed 
to be entirely reliable. However, no responsibility Is assumed for Inaccuracies 
Furthermore, such information does not convey to the purchaser of the semteonductor 
devices described any licenses under the patent rights of SMC or others. SNH, 
reserves the right to make changes at any time In order to Improve design and supply 
the best product possible. 
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